这不是Rails特有的——我只是以Rails为例。我在Rails中有一个模型:classItem(假设Item模型(类)有一个名为name的方法。)我什么时候需要使用self.name我什么时候可以只使用name(例如,#{name})? 最佳答案 在调用方法时更喜欢省略self.是惯用的;通常不需要。调用setter方法时,您必须使用self.foo=xxx,而不是foo=xxx,以便Ruby意识到您没有尝试创建新的局部变量。同样,如果您有一个与方法同名的现有局部变量do_something,这不太可能发生,您必须使用self.d
在Ruby中获取block返回true的第一个可枚举元素的最快方法是什么?例如:arr=[12,88,107,500]arr.select{|num|num>100}.first#=>107我不想像select那样遍历整个数组,因为我只需要第一个匹配项。我知道我可以做一个each并在成功时中断,但我认为有一个本地方法可以做到这一点;我只是没有在文档中找到它。 最佳答案 几个核心ruby类,包括Array和Hash包括Enumerable模块提供了许多有用的方法来处理这些枚举。此模块提供findordetectmethods这正是
所以我知道bang(感叹号)和非bang方法之间的区别通常是该方法是修改对象本身还是返回一个单独的修改后的对象,保持原始不变。然后在本书第6章构建User模型时,我遇到了User.create方法,它创建一个新模型并将其保存到数据库中。在MichaelHartl的RubyonRails3教程中,他写道User.create!方法“就像create方法一样工作......除了如果创建失败,它会引发一个ActiveRecord::Record-Invalid异常。”我很困惑。User.create!方法不遵循Ruby的“bang-convention”还是我完全遗漏了什么?如果他遵循约定,
我正在用Ruby1.9.2编写一个模块,它定义了几个方法。当调用这些方法中的任何一个时,我希望它们中的每一个都先执行特定的语句。moduleMyModuledefgo_forthare-usedstatement#codeparticulartothismethodfollows...enddefand_multiplyare-usedstatement#thensomethingcompletelydifferent...endend但我想避免在每个方法中显式地放置那个重用语句代码。有办法吗?(如果重要的话,重用语句将让每个方法在调用时打印自己的名称。它将通过puts__method
我想定义一个返回第二天的实例方法Date#next。所以我制作了一个DateExtension模块,如下所示:moduleDateExtensiondefnext(symb=:day)dt=DateTime.now{:day=>Date.new(dt.year,dt.month,dt.day+1),:week=>Date.new(dt.year,dt.month,dt.day+7),:month=>Date.new(dt.year,dt.month+1,dt.day),:year=>Date.new(dt.year+1,dt.month,dt.day)}[symb]endend使用它:
在rspec文档中说明我应该使用double方法来创建测试替身。但我可以看到,即使我不使用double,它也能正常工作。不使用double有什么问题吗?另外,如果我不使用doubleMyClass如何获取stub和其他rspec方法?在rspec中运行时,它们是否可用于所有对象?require'spec_helper'classMyClassdefself.runnew.executeenddefexecute'foo'endenddescribeMyClassdoit'shouldstubinstancemethod'doobj=MyClass.newobj.stub(:execut
我目前正在开发一个基于Rack的应用程序,并希望将所有文件请求(例如filename.filetype)重定向到指定的文件夹。Rack::Static仅支持对特殊文件夹(例如“/media”)的文件请求。我是否必须编写自己的Rack中间件或是否存在开箱即用的解决方案? 最佳答案 要将每个请求重定向到特定路径,请使用Rack::File(出于某种原因,最近的文档中没有此类,但它是stillpartof最新的Rack):runRack::File.new("/my/path")要重定向每个请求,并在目标目录中添加所有文件的HTML索引,
我在docs中阅读了有关Ruby字符串方法的内容并遇到了这些方法污点信任清除污点不信任我不知道他们是干什么的,我们用在什么情况下?有人用过吗?例子会很好。 最佳答案 taint和trust是Ruby安全模型的一部分。在Ruby中,每个对象都有一些随身携带的标志,其中两个是Trusted标志和Tainted标志。这些标志的作用取决于称为安全级别的东西。安全级别存储在$SAFE中。程序中的每个线程和纤程都可以有自己的安全级别。安全级别范围从0到4,其中0不强制执行安全性,而4强制执行太多,因此只应在您evaling代码时使用。您不能为$
我有一个yield方法,它看起来像:defa_method(*params)#dosomethingyield#dosomethingelseend如果传入block,我希望此方法产生block;如果没有block传入,该方法应该悄悄地跳过yieldsentense而不会崩溃:noblockgiven(yield)(LocalJumpError)当然,最直接的方法就是把方法改成:defa_method(*params,&block)#dosomethingyieldifblock#dosomethingelseend但是没有更漂亮的方法吗? 最佳答案
这是在Rails/Ruby中将字符串转换为类的方法:p="Post"Kernel.const_get(p)eval(p)p.constantize但是,如果我从数组/事件记录对象中检索方法,如:Post.description但也有可能是Post.anything其中anything是一个字符串,如anything="description"。这很有用,因为我想重构一个非常大的类并减少代码行和重复。我怎样才能让它发挥作用? 最佳答案 Post.send(anything) 关于ruby-